<template>
    <div>
        <Title :title="title"></Title>
        <div ref="left1" style="height: 150px; margin-top: 30px;"></div>
    </div>
</template>
<script>
// import { Color } from '@antv/g2/lib/dependents';
// 引入折线图的构造函数
import { Line } from '@antv/g2plot';
import { get } from '@/utils/request';
import moment from 'moment';
import { mapState } from 'vuex';
// import Title from './Title.vue';

export default {
    data() {
        return {
            title: '实时温度曲线',
            params: {
                page: 1,
                pageSize: 100
            },
            // 存放温度数据
            tempData: [],
            // 创建一个图表实例
            line:null
        }
    },
    computed:{
        ...mapState(['ed'])
    },
    watch:{
        ed:{
            handler(n,o){
                // 根据设备信息 重新查询数据 重新渲染图表
                this.params.engineer_id = n.engineer_id;
                this.params.device_id = n.device_id;
                this.getTempData();
                // 根据重新获取的诗句重新渲染图表
                this.line.changeData(this.tempData);
            },
            // 深度监听
            deep:true
        }
            
    },
    methods: {
        // 封装加载折线图的图表函数
        loadLine() {

            // 创建折线图表实例对象
            this.line = new Line(this.$refs.left1, {
                // 将后端获取的数据设置给data属性
                data: this.tempData,
                xField: 'insert_time',
                yField: 'temperature',
                // 配置x轴字段对象
                xAxis: {

                    label: {

                        rotate: -45,
                        style: {
                            fill: "white",
                            fontSize: 13
                        }
                    }
                },
                // 配置y轴对象
                yAxis: {
                    label: {
                        style: {
                            fill: "white",
                            fontSize: 13
                        }
                    }
                },
                label: {
                    style: {
                        fill: "white",
                        fontSize: 13
                    },
                },
                point: {
                    size: 5,
                    shape: 'diamond',
                    style: {
                        fill: 'white',
                        stroke: '#5B8FF9',
                        lineWidth: 2,
                    },
                },
                // 曲线是否平滑
                smooth: true,
                animation: {
                    appear: {
                        animation: 'wave-in',
                        duration: 5000,
                    },
                },
                tooltip: {
                    showMarkers: false,
                    domStyles: {
                        "g2-tooltip": {
                            background: '#147',
                            color: "white",
                            fontSize: 20
                        }
                    }
                },
                state: {
                    active: {
                        style: {
                            shadowBlur: 4,
                            stroke: '#000',
                            fill: 'red',
                        },
                    },
                },
                interactions: [{ type: 'marker-active' }],
            });
            // 渲染折线图表
            this.line.render();
        },
        // 封装一个方法 获取后端接口实时数据
        async getTempData() {
            let res = await get('/dashboard/pageQueryTodayData', this.params);
            console.log(res, "获取响应");
            let temp = [];
            // 将后端获取的数据设置
            res.data.list.forEach((item, index, arr) => {
                // 由于刻度混乱 将第一条数据进行处理
                arr[0].temperature =15.4;
                //item表示数组每一项
                item.insert_time = moment(item.insert_time).format("HH:mm");
                //数据查询密集需要数据处理 每隔10条数据取一条数据
                if (index % 10 == 0) {
                    temp.push(arr[index])
                }
            })


            this.tempData = temp;
        }
    },
    // 最早获取dom元素的生命周期 图表渲染dom元素
    async mounted() {
        await this.getTempData();
        this.loadLine();
    }
}
</script>
<style lang="less" scoped></style>